package com.frinder.data.base;

import org.springframework.data.mongodb.core.query.Query;

import java.util.List;

/**
 * @ClassName IService
 * @Description 数据库操作服务类
 * @Author frinder
 * @Date 2020/8/5 11:16
 * @Verion 1.0
 */
public interface IService<T> {
    /**
     * 添加
     *
     * @param target
     */
    void save(T target);

    /**
     * 更新
     *
     * @param id
     * @param target
     * @return
     */
    int update(String id, T target);

    /**
     * 删除
     *
     * @param id
     * @return
     */
    void delete(String id);

    /**
     * 批量删除
     *
     * @param ids
     */
    void delete(List<String> ids);

    /**
     * 全量查询
     *
     * @return
     */
    List<T> listAll();

    /**
     * 批量查询
     *
     * @param query
     * @return
     */
    List<T> list(Query query);

    /**
     * 单个查询
     *
     * @param id
     * @return
     */
    T findById(String id);

    /**
     * 根据业务标识查询
     *
     * @param sid
     * @return
     */
    T findBySid(String sid);

    /**
     * 分页查询
     *
     * @param page
     * @return
     */
    PageInfo<T> page(PageWrapper<T> page);

}
